package tree;

/**
 * @author kaho
 * @since 2021/2/25
 */
public class _111_二叉树的最小深度 {

    /**
     * 给定一个二叉树，找出其最小深度。
     *
     * 最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
     *
     * 说明：叶子节点是指没有子节点的节点。
     * @param root
     * @return
     *
     */
    public int minDepth1(TreeNode root){
        if (root == null) {
            return 0;
        }
        if (root.left==null&&root.right==null) {
            return 1;
        }
        int left = minDepth1(root.left);
        int right = minDepth1(root.right);
        if (root.left==null||root.right==null) {
            return left+right+1;
        }
        return Math.min(left, right)+1;
    }

    public int minDepth(TreeNode root) {
        if (root == null) {
            return 0;
        }
        if (root.left ==null && root.right==null) {
            return 1;
        }
        int left = minDepth(root.left);
        int right = minDepth(root.right);
        if (root.left==null || root.right ==null) {
            return left+right+1;
        }
        return Math.min(left,right)+1;
    }
}
